CLAIMS 



5 1. A method for inspecting any of the properties of a computer, said 
computer's configuration, contents of said computer's storage devices, said 
computer's peripherals, said computer's environment, or remote affiliated 
computers, comprising the steps of: 

providing at least one inspector library which includes at least one 
1 0 library and associated methods; evaluating subexpressions with said at 

least one inspector; and 

said inspector performing any of mathematico-logical calculations, 
executing computational algorithms, returning results of system calls, 
accesseing contents of storage devices, and querying devices or remote 
1 5 computers to inspect any of said properties of said computer, said computer's 
configuration, contents of said computer's storage devices, said computer's 
peripherals, said computer's environment, or remote affiliated computers. 

2. The method of Claim 1 , further comprising the step of: 
20 providing an inspector dispatcher associated with an advice client 

computer for continually performing relevance determination; 

wherein said relevance determination is driven by a database of 
relevance clauses which can be continually evaluated. 

25 3. The method of Claim 1 , further comprising the steps of: 
sending certain relevance clauses to a remote location; 
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evaluating said clauses; and 

returning said clauses after a user is made aware of what is being 
transferred; 

wherein properties of said remote location are learned. 

5 

4. The method of Claim 1, wherein relevance evaluation is driven in a 
master-slave relationship by a master machine which tells a slave 
machine to evaluate a relevance clause. 

10 5. The method of Claim 1, wherein properties which can be learned are 
an arbitrary combination of elementary properties that are determined 
according to basic calculations. 

6. The method of Claim 1, wherein said at least one inspector is built into 
1 5 said 

inspector dispatcher. 

7. The method of Claim 1 , further comprising the step of: 

providing one or more caches for avoiding heavy CPU and disk access 
20 overhead while successfully performing said continual relevance evaluation. 

8. The method of Claim 2, wherein an object, property name, and/or 
string selector is dispatched to said inspector dispatcher for relevance 
evaluation using a method dispatch module in accordance with dispatch 

25 information contained within a method dispatch table. 
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9. The method of Claim 8, wherein said method dispatch module 
performs the steps of: 

parsing a clause in a relevance language; 

generating a list of method dispatches in response to said parsing step, 
5 wherein specific methods are called in a specific order with specific argument 
lists; and 

systematically carrying out a sequence of method dispatches in an 
appropriate order. 

10 

10. An inspector library for inspecting any of the properties of a computer, 
said computer's configuration, contents of said computer's storage devices, 
said computer's peripherals, said computer's environment, or remote affiliated 
computers, said inspector library comprising: 

15 at least one inspector which is invoked as part of a continual relevance 

evaluation process; and 

one or more inspector methods for performing any of mathematico- 
logical calculations, executing computational algorithms, returning the results 
of system calls, accessing the contents of storage devices, and querying 

20 devices or remote computers to inspect any of the properties of a computer, 
said computer's configuration, contents of said computer's storage devices, 
said computer's peripherals, said computer's environment, or remote affiliated 
computers. 

25 11. The apparatus of Claim 10, further comprising: 
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an inspector dispatcher associated with an advice client computer for 
continually performing relevance determination, wherein said relevance 
determination is driven by a database of relevance clauses which can be 
continually evaluated; 
5 wherein said inspector library is invoked by said inspector dispatcher 

as part of said relevance determination process. 

12. The apparatus of Claim 10, wherein certain relevance clauses are sent 
to a remote location, evaluated, and returned, after a user is made aware of 

1 0 what is being transferred, wherein properties of the remote location can be 
learned. 

13. The apparatus of Claim 10, wherein relevance evaluation is driven in a 
master-slave relationship by a master machine which tells a slave machine to 

1 5 evaluate a relevance clause. 

14. The apparatus of Claim 10, wherein properties which can be learned 
are an arbitrary combination of elementary properties that are determined 
according to basic calculations. 

20 

15. The apparatus of Claim 10, further comprising: 

one or more caches for avoiding heavy CPU and disk access overhead 
while successfully performing said continual relevance evaluation. 

25 16. The apparatus of Claim 15, said inspector library further comprising 
any of: 
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a declaration of a [Phrase] to be used in a relevance language; 
an association of said [Phrase] to a specific method; 
a declaration of a new data type to be used in an evaluation process; 
a declaration of a calling prototype of said specific method, including a 
5 number and required data types of arguments to be supplied to said specific 
method; 

a declaration of a result data type of said specific method; 

an implementation of said specific method in executable form; 

a declaration of special hooks associating code to be called on events, 
10 said events including any of inspector dispatcher initialization, inspector 
dispatcher termination, beginning of inspector dispatcher main evaluation 
loop, and ending of inspector dispatcher main evaluation loop; 

a declaration of special hooks associated with creation and 
maintenance of special caches associated with said specific method; and 
15 an implementation of special event methods and cache methods in 

executable form. 

1 7. The apparatus of Claim 1 0, further comprising: 
a module for linking said inspector library into said inspector dispatcher with 
20 all declarations evaluated, resulting in changes to said inspector dispatcher's 
internal data structures, wherein new method invocations become available to 
said inspector dispatcher. 

25 18. The apparatus of Claim 17, further comprising: 
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a syntax table for providing said resulting changes to all allowed 
phrases and associated data types on which they operate; and 

a dispatch table for systematically determining an associated 
executable method for given phrase and data types. 

5 

19. The apparatus of Claim 1.0, wherein said inspector library is 
implemented in an object oriented language. 

20. The apparatus of Claim 10, wherein a plurality of inspector libraries 
1 0 are installed in an instance of said inspector dispatcher to define a set of 

recognized Phrases in a relevance language, a set of allowable data types at 
evaluation time, and a set of methods associated with those data types. 

21. The apparatus of Claim 10, wherein inspector libraries are created by 
15 advice providers and downloaded to a client computer as part of a site 

synchronization. 

22. The apparatus of Claim 10, wherein said inspector libraries are linked 
into said inspector dispatcher at the time said inspector dispatcher is 

20 initialized; and 

wherein declaration routines are invoked, new Phrases are installed in 
a lexical analysis table of a relevance language, and said new Phrases are 
associated to certain method invocations when said linking occurs. 

25 23. The apparatus of Claim 10, further comprising any of: 
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a base layer comprising a mechanism for elementary operations 
including any of arithmetic and logic, which are system-independent; 

a system-specific layer associated with a specific operating system; 

one or more vendor-specific layers for providing access to specific 
hardware devices and software products; and 

additional layers as appropriate, based on other advice providers. 

24. The apparatus of Claim 10, wherein said inspector inspects any of a 
version property of an application and properties of files including any of 
checksum, length, date, and date modified; and wherein said inspector 
verifies existence and configuration of any of files, directories, and file 
systems under a specific operating system. 

25. The apparatus of Claim 10, wherein said inspector comprises: 

a system specific inspector for accessing properties of an operating 
system and allowing advice to be written to verify the existence and 
configuration of attached devices and other subsystems. 

26. The apparatus of Claim 10, wherein said inspector comprises: 

a registry inspector for enabling a relevance language to refer to and 
evaluate properties of a registry database. 

27. The apparatus of Claim 10, wherein said inspector comprises: 

a preferences inspector for enabling a relevance language to refer to 
and evaluate properties of a preferences file of a specific application. 



28. The apparatus of Claim 10, wherein said inspector comprises: 

a database inspector for enabling a relevance language to access 
fields in a database. 

5 29. The apparatus of Claim 10, wherein said inspector comprises: 

a user profile inspector for enabling a relevance language to refer to 
data stored in a user profile. 

30. The apparatus of Claim 29, wherein said user profile comprises a 
10 dynamically expanding database, such that an advice provider, following a 

recognized procedure, may add new variables to the database and prompt 
the user for the values of those variables. 

31 . The apparatus of Claim 30, further comprising: 

15 a template file for describing a collection of variables to which an 

advice provider plans to refer in advisories; 

wherein said template file is placed at an advice site and is 
automatically gathered at a synchronization time; 

wherein said template file is used to drive an editing module on a client 
20 computer which presents a user with a list of template variable names and a 
list of their current values or blanks if they have not previously been defined; 
and 

wherein said user can fill in said blank fields and edit other fields. 

25 

32. The apparatus of Claim 10, wherein said inspector comprises: 
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a remote inspector for inspecting properties of other communicating 
devices. 

33. The apparatus of Claim 32, wherein said remote inspector inspects any 
of: 

remote physical measurements; 
remote device queries; 
remote computation; 
remote database queries; and 
remote relevance invocation. 

34. The apparatus of Claim 10, wherein said inspector comprises: 

a program log inspector for enabling a relevance language to refer to 
data stored in a specific log file or files associated with any specific 
application, wherein said specific log file may comprise any of a web browser 
log, a telecommunications log, a fax log, or a clickstream log. 

35. The apparatus of Claim 10, wherein said inspector comprises: 

an advice system inspector for enabling a relevance language to refer 
to data stored and managed by said inspector dispatcher. 

36. The apparatus of Claim 35, wherein said inspector inspects any of: 
a subscription database; 

an advice database; 
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inspector dispatchers log files; and 
an inspector dispatchers configuration. 



37. In a system including computational devices connected by a 
5 communications network, said system comprising a communications 
apparatus for linking an information provider to information consumer, said 
communications apparatus comprising specific units of advice to be shared, 
digital documents conveying said advice, an advice provider for broadcasting 
said advice in the form of advisories, an advice consumer for receiving said 

10 advisories, wherein advisories are broadcast over said communications 
network from said advice provider to said advice consumer, a 
communications protocol for narrowly-focused targeting of said advisories to 
said advice consumer by automatically matching advisories with an advice 
consumer for whom said advisories are relevant, and an inspector dispatcher 

1 5 associated with an advice client computer for continually performing relevance 
determination, wherein said relevance determination is driven by a database 
of relevance clauses which can be continually evaluated, at least one 
inspector library, comprising: 

at least one inspector; and 

20 associated methods for evaluating subexpressions with said at least 

one inspector; 

wherein said inspector library is invoked by said inspector dispatcher 
as part of said relevance determination process; and 

wherein said inspector performs any of mathematico-logical 
25 calculations, executes computational algorithms, returns the results of system 
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calls, accesses the contents of storage devices, and queries devices or 
remote computers. 



38. The apparatus of Claim 37, further comprising: 

5 one or more caches for avoiding heavy CPU and disk access overhead 

while successfully performing said continual relevance evaluation. 

39. The apparatus of Claim 37, wherein relevance is determined by looking 
at a database on a server and not by immediate calculation, where said 

1 0 database arose by inspection once or periodically according to an inspector 
library. 

40. A method for inspecting at a remote location any of the properties of a 
computer, said computer's configuration, contents of said computer's 

15 storage devices, said computer's peripherals, said computer's 

environment, or remote affiliated computers, comprising the steps of: 
sending one or more relevance clauses to said remote location; 
providing at least one inspector library at said remote location which 
includes at least one inspector and associated methods; evaluating 

20 said one or more relevance clauses with said at least one inspector; 

and 

returning evaluation results after a user is made of what is being 
transferred. 

25 41 . In a system comprising a master computer, a method for inspecting any of 
the properties of a slave computer, said slave computer's configuration, 
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contents of said slave computer's storage devices, said slave computer's 
peripherals, said slave computer's environment, or remote affiliated 
computers, comprising the steps of: 

providing at least one inspector library which includes at least one 
5 inspector and associated methods; evaluating one or more relevance 

clauses with said at least one inspector; 

wherein said relevance clauses evaluation proceeds in connection with 
said slave computer as controlled by said master computer. 
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